<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
    <!-- 1、导入 ol 依赖 -->
    <link rel="stylesheet" href="https://lib.baomitu.com/ol3/4.6.5/ol.css" />
    <script src="https://lib.baomitu.com/ol3/4.6.5/ol.js"></script>
  </head>
  <body>
    <!-- 2、设置地图挂载点（容器） -->
    <div id="map" style="width: 100%; height: 100%"></div>
    <!-- 3、初始化高德图层 -->
    <script>
      // 3、初始化高德图层
      const gaode = new ol.layer.Tile({
        title: "高德地图",
        source: new ol.source.XYZ({
          url: "http://wprd0{1-4}.is.autonavi.com/appmaptile?lang=zh_cn&size=1&style=7&x={x}&y={y}&z={z}",
          wrapX: false,
        }),
      });
      // 4、初始化 openlayer 地图
      const map = new ol.Map({
        target: "map", // 将初始化的地图挂在到 id 为 map 的 dom 元素上
        layers: [gaode], // 设置图层
        // view：设置视图
        view: new ol.View({
          center: [114.3, 30.5], // 地图中心点
          zoom: 10, // 地图缩放级别
          projection: "EPSG:4326", // 地图投影
          // maxZoom: 18,
        }),
      });
      // 创建 geojson 对象
      var data = {
        type: "FeatureCollection",
        features: [
          {
            type: "Feature",
            geometry: {
              type: "Point",
              coordinates: [114.3, 30.5],
            },
          },
        ],
      };
      // 将数据添加到矢量数据源中
      var source = new ol.source.Vector({
        features: new ol.format.GeoJSON().readFeatures(data),
      });
      // 将矢量数据源添加到矢量图层中
      var layer = new ol.layer.Vector({
        source,
      });
      // 创建样式数据
      const style = new ol.style.Style({
        image: new ol.style.Circle({
          radius: 10,
          fill: new ol.style.Fill({
            color: "#ff2d51",
          }),
          stroke: new ol.style.Stroke({
            color: "black",
            width: 2,
          }),
        }),
      });
      // 将样式设置到图层
      layer.setStyle(style);
      // 将矢量图层添加到地图上
      map.addLayer(layer);
    </script>
  </body>
</html>
